MYSQL相关之不常见变量、排序函数、JDBC数据库与Java连接 您所在的位置:网站首页 Java label函数 MYSQL相关之不常见变量、排序函数、JDBC数据库与Java连接

MYSQL相关之不常见变量、排序函数、JDBC数据库与Java连接

2023-05-15 23:03| 来源: 网络整理| 查看: 265

本文源自Recently祝祝,创自Recently祝祝。转载请标注出处

image.png

1.MYSQL变量分两类 用户自定义变量 局部变量--->只在当前begin/end代码块中有效 create procedure add ( in a int, in b int ) begin declare c int default 0; set c = a + b; select c as c; end;

image.png 2.用户变量--->在客户端链接到数据库实例整个过程中用户变量都是有效的。

系统变量 会话变量-->会话变量的作用域与用户变量一样,仅限于当前连接。当当前连接断开后,其设置的所有会话变量均失效。@@session.变量名 或者@@local.变量名

4.全局变量-->全局变量影响服务器整体操作。@@global.变量名

DEMO解释排序函数

按员工底薪排序并且标明顺序。 按照实例模仿,可以学会排序函数的使用方式。实例下边也进行了解释。Oracle中存在row_number,rank,dense_rank函数,而Mysql中需要模仿处理,下边实例都是在Mysql中进行实现的。

DEMO1: -- 排序函数 -- row_number,rank,dense_rank USE mytest;

row_number row_number简写rn,可以根据需求进行命名 使用名为“@rn”的变量来跟踪行号。我们使用子查询 (SELECT @rn := 0) 将其初始化为 0,然后使用表达式“@rn := @rn + 1”为每一行将其递增 1。

-- row_number SELECT empno,ename,sal,@rn:=@rn+1 rn FROM emp,(SELECT @rn:=0)t1 ORDER BY sal DESC;

在这里插入图片描述

Demo2:

dense_rank dense_rank就是除了使用row_number-》rn,还使用了一个rank变量,rank就是下边实例中的sal.

-- dense_rank SELECT empno,ename,sal, IF(@sal=sal,@rn,@rn:=@rn+1) rn, @sal:=sal FROM emp,(SELECT @rn:=0,@sal:=0) t1 ORDER BY sal DESC;

检索“emp”表中所有员工的员工编号 (empno)、员工姓名 (ename) 和薪水 (sal),同时还按降序为每一行生成行号 (rn)的薪水。查询使用变量 (@rn) 来跟踪行号。在执行主查询之前,该变量在子查询 (t1) 中被初始化为 0。 在这里插入图片描述

DEMO3:

-- rank

-- rank SELECT empno,ename,sal,@r:=@r+1, IF(@sal=sal,@rn,@rn:=@r) rn, @sal:=sal FROM emp,(SELECT @rn:=0, @r:=0,@sal:=0) t1 ORDER BY sal DESC;

使用变量模拟 MySQL 中 ROW_NUMBER() 函数的行为。

“@rn”变量用于跟踪行号。 “@r”变量用于跟踪排名。 “@sal”变量用于跟踪以前的薪水值。 子查询将所有变量初始化为 0。 SELECT 语句检索员工编号、姓名、薪水,并生成行号和级别。 “@r”变量每行递增 1。 IF() 函数检查当前薪水值是否与以前的薪水值相同。如果它们相同,则“@rn”变量用作当前行的排名。如果它们不同,则使用“@r”变量作为当前行的排名,并将“@rn”变量设置为“@r”的值。 “@sal”变量用当前薪水值更新,以便在下一行进行比较。 结果集按薪水降序排列。 在这里插入图片描述 DEMO4: -- 将员工的信息,按照部门和底薪排序,并标明顺序 SELECT empno,ename,deptno,sal, IF(@sal=sal,@rn,@rn:=@rn+1), IF(@deptno=deptno,@rn,@rn:=1) rn, @deptno:=deptno, @sal:=sal FROM emp,(SELECT @rn:=0,@sal:=0,@deptno:=0) t1 ORDER BY deptno,sal DESC;

检索“emp”表中所有员工的员工编号 (empno)、员工姓名 (ename) 和薪水 (sal),同时还按降序为每一行生成行号 (rn)的薪水。

此外,它检查当前行的薪水是否与上一行的薪水相同,如果是,则为当前行分配与上一行相同的行号。使用三个变量(@rn、@r 和@sal)来跟踪行号、基于薪水的行排名以及之前的薪水值。

在执行主查询之前,变量在子查询 (t1) 中被初始化为 0。主查询首先为每一行递增 @r 变量以生成基于薪水的排名。然后它使用 IF 语句将当前薪水 (@sal) 与以前的薪水值进行比较。

如果它们相同,则为当前行分配与前一行相同的行号(@rn);否则,它使用@r 变量分配一个新的行号(@rn)。最后,它用当前行的薪水更新@sal 变量,以便在下一行进行比较。 ORDER BY 子句按薪水的降序对结果集进行排序。 在这里插入图片描述

JDBC数据库与Java连接

概述: JDBC是Java访问数据库的标准规范,可以为不同的关系型数据库提供统一访问,它由一组用Java语言编写的接口和类组成。

在这里插入图片描述 JDBC规范(掌握四个核心对象):

DriverManager:用于注册驱动 Connection: 表示与数据库创建的连接 Statement: 操作数据库sql语句的对象 ResultSet: 结果集或一张虚拟表 JDBC连接数据库基础六部

第一步:注册驱动 Class.forName("com.mysql.jdbc.Driver");

第二步:建立连接 这一步注意修改数据库名称以及密码,和数据库地址 conn=DriverManager.getConnection("jdbc:mysql://localhost/test1","root","123456");

第三步:创建Statement对象 st=conn.createStatement();

end》》》

智者见智,仁者见仁,一个好的价值观念会让你懂得许多,学会更多,得到很多



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有